# **Rockchip Developer Guide Linux GMAC Mode Configuration**

文件标识: RK-KF-YF-144

发布版本: V1.1.0

日期: 2021-12-28

文件密级:□绝密 □秘密 □内部资料 ■公开

免责声明

本文档按"现状"提供,瑞芯微电子股份有限公司("本公司",下同)不对本文档的任何陈述、信息和内容的准确性、可靠性、完整性、适销性、特定目的性和非侵权性提供任何明示或暗示的声明或保证。本文档仅作为使用指导的参考。

由于产品版本升级或其他原因,本文档将可能在未经任何通知的情况下,不定期进行更新或修改。

商标声明

"Rockchip"、"瑞芯微"、"瑞芯"均为本公司的注册商标,归本公司所有。

本文档可能提及的其他所有注册商标或商标,由其各自拥有者所有。

版权所有 © 2021 瑞芯微电子股份有限公司

超越合理使用范畴,非经本公司书面许可,任何单位和个人不得擅自摘抄、复制本文档内容的部分或全部,并不得以任何形式传播。

瑞芯微电子股份有限公司

Rockchip Electronics Co., Ltd.

地址: 福建省福州市铜盘路软件园A区18号

网址: <u>www.rock-chips.com</u>

客户服务电话: +86-4007-700-590

客户服务传真: +86-591-83951833

客户服务邮箱: fae@rock-chips.com

前言

# 概述

本文提供 Rockchip 平台以太网 GMAC 接口不同模式下的配置用例,用于解决以太网配置问题。

# 产品版本

| 芯片名称        | 内核版本 |
|-------------|------|
| ROCKCHIP 芯片 | 所有版本 |

# 读者对象

本文档(本指南)主要适用于以下工程师:

技术支持工程师

软件开发工程师

修订记录

| 版本号    | 作者  | 修改日期       | 修改说明   |
|--------|-----|------------|--------|
| V1.0.0 | 吴达超 | 2021-01-26 | 初始版本   |
| V1.1.0 | 吴达超 | 2021-12-28 | 支持3588 |

#### **Rockchip Developer Guide Linux GMAC Mode Configuration**

- 1. RGMII 模式
  - 1.1 PLL output 125M for TX CLK, Crystal 25M for PHY
  - 1.2 PLL output 125M for TX CLK, PLL 25M for PHY
  - 1.3 125M TX CLK input from PHY, PLL 25M for PHY
  - 1.4 125M TX CLK input from PHY, Crystal 25M for PHY
- 2. RMII 模式
  - 2.1 RMII Clock Output
  - 2.2 RMII Clock Input
- 3. 模式配置
  - 3.1 PX30
    - 3.1.1 RMII Clock Output
    - 3.1.2 RMII Clock Input
  - 3.2 RK1808
    - 3.2.1 RMII Clock Output:
    - 3.2.2 RMII Clock Input
    - 3.2.3 RGMII Clock Output
    - 3.2.4 RGMII Clock Input
  - 3.3 RK3128
    - 3.3.1 RMII Clock Output
    - 3.3.2 RMII Clock Input
    - 3.3.3 RGMII Clock Input
  - 3.4 RK3228
    - 3.4.1 RMII Clock Output
    - 3.4.2 RMII Clock Input
    - 3.4.3 RGMII Clock Output
    - 3.4.4 RGMII Clock Input
    - 3.4.5 Internal EPHY
  - 3.5 RK3288
    - 3.5.1 RMII Clock Output
    - 3.5.2 RMII Clock Input
    - 3.5.3 RGMII Clock Input
  - 3.6 RK3328
    - 3.6.1 RMII Clock Output
    - 3.6.2 RMII Clock Input
    - 3.6.3 RGMII Clock Input
    - 3.6.4 Internal EPHY
  - 3.7 RK3368
    - 3.7.1 RMII Clock Output
    - 3.7.2 RMII Clock Input
    - 3.7.3 RGMII Clock Input
  - 3.8 RK3399
    - 3.8.1 RMII Clock Output
    - 3.8.2 RMII Clock Input
    - 3.8.3 RGMII Clock Input
  - 3.9 RK3568
    - 3.9.1 RMII Clock Output
    - 3.9.2 RMII Clock Input
    - 3.9.3 RGMII PLL output 25M for PHY, PLL output 125M for TX CLK
    - 3.9.4 RGMII PLL output 25M for PHY, RGMII\_CLK input 125M for TX\_CLK
    - 3.9.5  $\,$  RGMII Crystal 25M for PHY, PLL output 125M for TX\_CLK
    - 3.9.6 RGMII Crystal 25M for PHY, RGMII\_CLK input 125M for TX\_CLK
    - 3.9.7 SGMII
    - 3.9.8 **QSGMII**
  - 3.10 RK3588

- 3.10.1 RMII Clock Output
- 3.10.2 RMII Clock Input
- 3.10.3 RGMII PLL output 25M for PHY, PLL output 125M for TX CLK
- 3.10.4 RGMII PLL output 25M for PHY, RGMII\_CLK input 125M for TX\_CLK
- 3.10.5 RGMII Crystal 25M for PHY, PLL output 125M for TX CLK
- 3.10.6 RGMII Crystal 25M for PHY, RGMII\_CLK input 125M for TX\_CLK

#### 3.11 RV1108

- 3.11.1 RMII Clock Input
- 3.11.2 RMII Clock Output

#### 3.12 RV1126

- 3.12.1 RGMII PLL output 25M for PHY, PLL output 125M for TX CLK
- 3.12.2 RGMII PLL output 25M for PHY, RGMII Clock input 125M for TX\_CLK
- 3.12.3 RGMII Crytal 25M for PHY, PLL output 125M for TX\_CLK
- 3.12.4 RGMII Crytal 25M for PHY, RGMII\_CLK input 125M for TX\_CLK
- 3.12.5 RMII Clock Output
- 3.12.6 RMII Clock Input

# 1. RGMII 模式

一般使用主控 PLL 输出 时钟 output 方式, PHY 提供的 125M 时钟作为 input 方式为备选方案。

# 1.1 PLL output 125M for TX CLK, Crystal 25M for PHY

主控 PLL 提供 TXCLK 所需时钟, PHY 25M 时钟由晶振提供。



# 1.2 PLL output 125M for TX\_CLK, PLL 25M for PHY

主控 PLL 提供 TXCLK 所需时钟, PHY 25M 时钟由主控提供。



# 1.3 125M TX\_CLK input from PHY, PLL 25M for PHY

TXCLK 所需时钟由 PHY 提供, PHY 25M 时钟由主控提供。



# 1.4 125M TX\_CLK input from PHY, Crystal 25M for PHY

TXCLK 所需时钟由 PHY 提供, PHY 25M 时钟由晶振提供。



# 2. RMII 模式

# 2.1 RMII Clock Output

主控提供 RMII 所需时钟



# 2.2 RMII Clock Input

PHY 提供 RMII 所需时钟



同样,RMII模式下,晶振也可以由主控输出25M替代。

# 3. 模式配置

不同模式下的配置主要包含了 phy mode, clock 和 pinctrl 的配置,这些配置都是关联的,需要同时配置,否则无法工作。

以下是各芯片不同模式下,以 SDK 板级 DTS 为例的不同配置方式的参考,关注 dts 中 gmac 节点里 '+' 部分的修改。

# 3.1 PX30

#### 3.1.1 RMII Clock Output

#### 3.1.2 RMII Clock Input

#### 3.2 RK1808

#### 3.2.1 RMII Clock Output:

```
&gmac {
       phy-supply = <&vcc phy>;
        phy-mode = "rmii";
        clocks = <&cru SCLK GMAC>, <&cru SCLK GMAC RX TX>,
                 <&cru SCLK GMAC RX TX>, <&cru SCLK GMAC REF>,
                 <&cru SCLK_GMAC_REFOUT>, <&cru ACLK_GMAC>,
                 <&cru PCLK GMAC>, <&cru SCLK GMAC RMII SPEED>;
        clock-names = "stmmaceth", "mac_clk_rx",
                       "mac clk tx", "clk mac ref",
                       "clk mac refout", "aclk mac",
                       "pclk_mac", "clk_mac_speed";
        assigned-clocks = <&cru SCLK GMAC RX TX>;
        assigned-clock-parents = <&cru SCLK GMAC RMII SPEED>;
       snps,reset-gpio = <&gpio0 10 GPIO ACTIVE LOW>;
       snps,reset-active-low;
       snps, reset-delays-us = <0 50000 50000>;
       pinctrl-names = "default";
        pinctrl-0 = <&rmii pins>;
       status = "okay";
```

#### 3.2.2 RMII Clock Input

```
+&gmac_clkin {
       clock-frequency = <50000000>;
+};
&gmac {
        phy-supply = <&vcc_phy>;
       phy-mode = "rmii";
        clock_in_out = "input";
        clocks = <&cru SCLK_GMAC>, <&cru SCLK_GMAC_RX_TX>,
                  <&cru SCLK GMAC RX TX>, <&cru SCLK GMAC REF>,
                  <&cru SCLK_GMAC_REFOUT>, <&cru ACLK_GMAC>,
                  <&cru PCLK_GMAC>, <&cru SCLK_GMAC_RMII SPEED>;
         clock-names = "stmmaceth", "mac_clk_rx",
                       "mac_clk_tx", "clk_mac_ref",
                       "clk mac refout", "aclk mac",
                       "pclk mac", "clk mac speed";
        assigned-clocks = <&cru SCLK_GMAC_RX_TX>, <&cru SCLK_GMAC>;
        assigned-clock-parents = <&cru SCLK_GMAC_RMII_SPEED>, <&gmac_clkin>;
        snps,reset-gpio = <&gpio0 10 GPIO_ACTIVE_LOW>;
        snps,reset-active-low;
        snps,reset-delays-us = <0 50000 50000>;
        pinctrl-names = "default";
        pinctrl-0 = <&rmii_pins>;
        status = "okay";
};
```

#### 3.2.3 RGMII Clock Output

```
phy-supply = <&vcc_phy>;

phy-mode = "rgmii";

clock_in_out = "output";

assigned-clocks = <&cru SCLK_MAC>;

assigned-clock-rates = <125000000>;

snps,reset-gpio = <&gpio0 10 GPIO_ACTIVE_LOW>;

snps,reset-active-low;

/* Reset time is 20ms, 100ms for rtl8211f */

snps,reset-delays-us = <0 20000 100000>;

tx_delay = <0x50>;

rx_delay = <0x3a>;

status = "okay";
};
```

#### 3.2.4 RGMII Clock Input

```
phy-supply = <&vcc_phy>;

phy-mode = "rgmii";

clock_in_out = "input";

assigned-clocks = <&cru SCLK_GMAC>;

assigned-clock-parents = <&gmac_clkin>;

snps,reset-gpio = <&gpio0 10 GPIO_ACTIVE_LOW>;

snps,reset-active-low;

/* Reset time is 20ms, 100ms for rtl8211f */

snps,reset-delays-us = <0 20000 100000>;

tx_delay = <0x50>;

rx_delay = <0x3a>;

status = "okay";
};
```

#### 3.3 RK3128

# 3.3.1 RMII Clock Output

#### 3.3.2 RMII Clock Input

```
snps,reset-delays-us = <0 10000 50000>;
snps,reset-gpio = <&gpio2 24 GPIO_ACTIVE_LOW>;
status = "okay";
};
```

# 3.3.3 RGMII Clock Input

#### 3.4 RK3228

#### 3.4.1 RMII Clock Output

#### 3.4.2 RMII Clock Input

```
+&ext_gmac: external-gmac-clock {
+         clock-frequency = <50000000>;
+}

&gmac {
```

```
+ assigned-clocks = <&cru SCLK_MAC_EXTCLK>, <&cru SCLK_MAC>;
+ assigned-clock-parents = <&ext_gmac>, <&cru SCLK_MAC_EXTCLK>;
+ clock_in_out = "input";
    phy-supply = <&vcc_phy>;
+ phy-mode = "rmii";
+ pinctrl-names = "default";
+ pinctrl-0 = <&rmii_pins>;
    snps,reset-gpio = <&gpio2 RK_PDO GPIO_ACTIVE_LOW>;
    snps,reset-active-low;
    snps,reset-delays-us = <0 20000 100000>;
    status = "okay";
};
```

## 3.4.3 RGMII Clock Output

```
&gmac {
        assigned-clocks = <&cru SCLK_MAC_EXTCLK>, <&cru SCLK_MAC>;
        assigned-clock-parents = <&ext_gmac>, <&cru SCLK_MAC_EXTCLK>;
       assigned-clock-rates = <0>, <125000000>;
        clock in out = "output";
      phy-supply = <&vcc phy>;
       phy-mode = "rgmii";
       pinctrl-names = "default";
       pinctrl-0 = <&rqmii pins>;
        snps,reset-gpio = <&gpio2 RK PD0 GPIO ACTIVE LOW>;
        snps, reset-active-low;
        snps,reset-delays-us = <0 20000 100000>;
       tx delay = <0x30>;
       rx delay = <0x10>;
       status = "okay";
};
```

#### 3.4.4 RGMII Clock Input

#### 3.4.5 Internal EPHY

```
&gmac {
        assigned-clocks = <&cru SCLK MAC SRC>;
       assigned-clock-rates = <50000000>;
        clock_in_out = "output";
      phy-supply = <&vcc_phy>;
        phy-mode = "rmii";
        phy-handle = <&phy>;
       status = "okay";
       mdio {
                compatible = "snps,dwmac-mdio";
                #address-cells = <1>;
                \#size-cells = <0>;
                phy: ethernet-phy@0 {
                        compatible = "ethernet-phy-id1234.d400", "ethernet-phy-
ieee802.3-c22";
                        reg = <0>;
                        clocks = <&cru SCLK MAC PHY>;
                        resets = <&cru SRST MACPHY>;
                        phy-is-integrated;
                };
       };
};
```

# 3.5 RK3288

#### 3.5.1 RMII Clock Output

#### 3.5.2 RMII Clock Input

```
+&ext_gmac: external-gmac-clock {
+ clock-frequency = <50000000>;
+}
```

# 3.5.3 RGMII Clock Input

#### 3.6 RK3328

#### 3.6.1 RMII Clock Output

#### 3.6.2 RMII Clock Input

```
+&clkin gmac {
      clock-frequency = <50000000>;
+};
&gmac2io {
      phy-supply = <&vcc phy>;
      phy-mode = "rmii";
       clock in out = "input";
       assigned-clocks = <&cru SCLK_MAC2IO>, <&cru SCLK_MAC2IO_EXT>;
        assigned-clock-parents = <&gmac_clkin>, <&gmac_clkin>;
       snps,reset-gpio = <&gpio1 RK PC2 GPIO ACTIVE LOW>;
       snps,reset-active-low;
      snps,reset-delays-us = <0 20000 100000>;
       pinctrl-names = "default";
       pinctrl-0 = <&rmiim1 pins>;
       status = "okay";
};
```

#### 3.6.3 RGMII Clock Input

## 3.6.4 Internal EPHY

#### 3.7.1 RMII Clock Output

## 3.7.2 RMII Clock Input

```
+&ext_gmac {
+ clock-frequency = <50000000>;
+}
&gmac {
      phy-supply = <&vcc_lan>;
      phy-mode = "rmii";
       clock in out = "input";
       assigned-clocks = <&cru SCLK_MAC>;
        assigned-clock-parents = <&ext_gmac>;
       snps, reset-gpio = < & gpio 3 12 0>;
       snps,reset-active-low;
      snps,reset-delays-us = <0 20000 100000>;
       pinctrl-names = "default";
       pinctrl-0 = <&rmii_pins>;
       status = "ok";
};
```

# 3.7.3 RGMII Clock Input

#### 3.8 RK3399

#### 3.8.1 RMII Clock Output

#### 3.8.2 RMII Clock Input

```
+&clkin gmac {
+ clock-frequency = <50000000>;
+};
&gmac {
      assigned-clocks = <&cru SCLK RMII SRC>;
       assigned-clock-parents = <&clkin gmac>;
       clock in out = "input";
      phy-supply = <&vcc_phy>;
       phy-mode = "rmii";
       pinctrl-names = "default";
       pinctrl-0 = <&rmii pins>;
       snps,reset-gpio = <&gpio3 RK_PB7 GPIO_ACTIVE_LOW>;
       snps,reset-active-low;
       snps,reset-delays-us = <0 20000 100000>;
       status = "okay";
} ;
```

#### 3.8.3 RGMII Clock Input

#### 3.9 RK3568

## 3.9.1 RMII Clock Output

• gmac0

```
&gmac0 {
       phy-mode = "rmii";
        clock_in_out = "output";
       assigned-clocks = <&cru SCLK GMACO RX TX>, <&cru SCLK GMACO>;
       assigned-clock-parents = <&cru SCLK GMAC0 RMII SPEED>;
        assigned-clock-rates = <0>, <50000000>;
        snps,reset-gpio = <&gpio3 RK PC2 GPIO ACTIVE LOW>;
        snps,reset-active-low;
        snps,reset-delays-us = <0 20000 100000>;
       pinctrl-names = "default";
       pinctrl-0 = <&gmac0 miim &gmac0 clkinout &gmac0 rx bus2 &gmac0 tx bus2>;
       phy-handle = <&rmii phy0>;
       status = "okay";
};
&mdio0 {
        rmii phy0: phy@0 {
               compatible = "ethernet-phy-ieee802.3-c22";
               reg = <0x0>;
        };
};
```

• gmac1m0:

```
&gmac1 {
+         phy-mode = "rmii";
```

```
clock in out = "output";
         assigned-clocks = <&cru SCLK_GMAC1_RX_TX>, <&cru SCLK_GMAC1>;
         assigned-clock-parents = <&cru SCLK GMAC1 RMII SPEED>;
        assigned-clock-rates = <0>, <50000000>;
        snps,reset-gpio = <&gpio3 RK_PC2 GPIO_ACTIVE_LOW>;
        snps, reset-active-low;
        snps,reset-delays-us = <0 20000 100000>;
        pinctrl-names = "default";
        pinctrl-0 = <&gmac1m0 miim &gmac1m0 clkinout &gmac1m0 rx bus2
&gmac1m0 tx bus2>;
       phy-handle = <&rmii_phy1>;
        status = "okay";
};
&mdio1 {
       rmii_phy1: phy@0 {
                compatible = "ethernet-phy-ieee802.3-c22";
                reg = <0x0>;
        };
};
```

#### • gmac1m1:

```
&gmac1 {
        phy-mode = "rmii";
       clock in out = "output";
       assigned-clocks = <&cru SCLK_GMAC1_RX_TX>, <&cru SCLK_GMAC1>;
        assigned-clock-parents = <&cru SCLK_GMAC1_RMII_SPEED>;
        assigned-clock-rates = <0>, <50000000>;
        snps,reset-gpio = <&gpio3 RK PC2 GPIO ACTIVE LOW>;
        snps,reset-active-low;
        snps,reset-delays-us = <0 20000 100000>;
        pinctrl-names = "default";
        pinctrl-0 = <&gmac1m1 miim &gmac1m1 clkinout &gmac1m1 rx bus2
&gmac1m1_tx_bus2>;
       phy-handle = <&rmii_phy1>;
        status = "okay";
&mdio1 {
       rmii phy1: phy@0 {
               compatible = "ethernet-phy-ieee802.3-c22";
               reg = <0x0>;
       };
} ;
```

## 3.9.2 RMII Clock Input

• gmac0

```
+&gmac0 clkin{
+ clock-frequency = <50000000>;
+};
&gmac0 {
      phy-mode = "rmii";
       clock_in_out = "input";
        snps,reset-gpio = <&gpio3 RK PC2 GPIO ACTIVE LOW>;
        snps, reset-active-low;
        snps,reset-delays-us = <0 20000 100000>;
        assigned-clocks = <&cru SCLK GMACO RX TX>, <&cru SCLK GMACO>;
        assigned-clock-parents = <&cru SCLK GMAC0 RMII SPEED>, <&gmac0 clkin>;
       pinctrl-names = "default";
        pinctrl-0 = <&gmac0_miim &gmac0_clkinout &gmac0_rx_bus2 &gmac0_tx_bus2>;
       phy-handle = <&rmii phy0>;
       status = "okay";
} ;
&mdio0 {
       rmii phy0: phy@0 {
               compatible = "ethernet-phy-ieee802.3-c22";
               reg = <0x0>;
       };
};
```

#### • gmac1m0:

```
+&gmac1 clkin{
+ clock-frequency = <50000000>;
+};
&gmac1 {
+ phy-mode = "rmii";
       clock in out = "input";
       snps,reset-gpio = <&gpio3 RK PC2 GPIO ACTIVE LOW>;
       snps, reset-active-low;
       snps, reset-delays-us = <0 20000 100000>;
       assigned-clocks = <&cru SCLK GMAC1 RX TX>, <&cru SCLK GMAC1>;
       assigned-clock-parents = <&cru SCLK GMAC1 RMII SPEED>, <&gmac1 clkin>;
       pinctrl-names = "default";
       pinctrl-0 = <&gmac1m0 miim &gmac1m0 clkinout &gmac1m0 rx bus2
&gmac1m0 tx bus2>;
       phy-handle = <&rmii_phy1>;
       status = "okay";
};
```

#### • gmac1m1:

```
+&gmac1_clkin{
      clock-frequency = <50000000>;
+};
&gmac1 {
+ phy-mode = "rmii";
       clock in out = "input";
        snps,reset-gpio = <&gpio3 RK_PC2 GPIO_ACTIVE_LOW>;
        snps,reset-active-low;
       snps,reset-delays-us = <0 20000 100000>;
        assigned-clocks = <&cru SCLK GMAC1 RX TX>, <&cru SCLK GMAC1>;
       assigned-clock-parents = <&cru SCLK GMAC1 RMII SPEED>, <&gmac1 clkin>;
       pinctrl-names = "default";
        pinctrl-0 = <&gmac1m1_miim &gmac1m1_clkinout &gmac1m1_rx_bus2</pre>
&gmac1m1_tx_bus2>;
       phy-handle = <&rmii_phy1>;
       status = "okay";
};
&mdio1 {
       rmii phy1: phy@0 {
               compatible = "ethernet-phy-ieee802.3-c22";
               reg = <0x0>;
       };
};
```

# 3.9.3 RGMII PLL output 25M for PHY, PLL output 125M for TX\_CLK

#### • gmac0

```
pinctrl-names = "default";
         pinctrl-0 = <&gmac0_miim</pre>
                      &gmac0 tx bus2
                      &gmac0 rx bus2
                       &gmac0 rgmii clk
                       &gmac0_rgmii_bus
                       &eth0 pins>;
        tx delay = <0x3c>;
        rx_delay = <0x2f>;
        phy-handle = <&rgmii phy0>;
        status = "okay";
};
&mdio0 {
        rgmii phy0: phy@0 {
                compatible = "ethernet-phy-ieee802.3-c22";
                reg = <0x0>;
                clocks = <&cru CLK_MAC0_OUT>;
        };
};
```

```
&gmac1 {
        phy-mode = "rgmii";
       clock in out = "output";
        snps,reset-gpio = <&gpio2 RK PD1 GPIO ACTIVE LOW>;
        snps,reset-active-low;
        /* Reset time is 20ms, 100ms for rtl8211f */
        snps, reset-delays-us = <0 20000 100000>;
        assigned-clocks = <&cru SCLK_GMAC1_RX_TX>, <&cru SCLK_GMAC1>, <&cru
CLK_MAC1_OUT>;
        assigned-clock-parents = <&cru SCLK_GMAC1_RGMII_SPEED>;
        assigned-clock-rates = <0>, <125000000>, <25000000>;
        pinctrl-names = "default";
         pinctrl-0 = < &gmac1m0_miim
                      &gmac1m0_tx_bus2
                      &gmac1m0 rx bus2
                      &gmac1m0 rgmii clk
                      &gmac1m0 rgmii bus
                      &eth1m0_pins>;
        tx delay = <0x4f>;
        rx_delay = <0x26>;
       phy-handle = <&rgmii phy1>;
        status = "okay";
} ;
&mdio1 {
        rgmii phy1: phy@0 {
                compatible = "ethernet-phy-ieee802.3-c22";
                reg = <0x0>;
```

```
+ clocks = <&cru CLK_MAC1_OUT>;
};
```

```
&gmac1 {
        phy-mode = "rgmii";
       clock_in_out = "output";
        snps,reset-gpio = <&gpio2 RK_PD1 GPIO_ACTIVE_LOW>;
        snps, reset-active-low;
        /* Reset time is 20ms, 100ms for rt18211f */
        snps,reset-delays-us = <0 20000 100000>;
        assigned-clocks = <&cru SCLK GMAC1 RX TX>, <&cru SCLK GMAC1>, <&cru
CLK MAC1 OUT>;
        assigned-clock-parents = <&cru SCLK_GMAC1 RGMII SPEED>;
        assigned-clock-rates = <0>, <125000000>, <25000000>;
         pinctrl-names = "default";
         pinctrl-0 = <&gmac1m1 miim</pre>
                      &gmac1m1_tx_bus2
                      &gmac1m1_rx_bus2
                      &gmac1m1_rgmii_clk
                      &gmac1m1 rgmii bus
                      &eth1m1 pins>;
        tx delay = <0x4f>;
        rx_delay = <0x26>;
        phy-handle = <&rgmii phy1>;
        status = "okay";
};
&mdio1 {
       rgmii phy1: phy@0 {
                compatible = "ethernet-phy-ieee802.3-c22";
               reg = <0x0>;
                clocks = <&cru CLK_MAC1_OUT>;
        };
};
```

#### 3.9.4 RGMII PLL output 25M for PHY, RGMII CLK input 125M for TX CLK

#### • gmac0

```
snps,reset-gpio = <&gpio2 RK PD3 GPIO ACTIVE LOW>;
        snps,reset-active-low;
        /* Reset time is 20ms, 100ms for rt18211f */
        snps, reset-delays-us = <0 20000 100000>;
        pinctrl-names = "default";
         pinctrl-0 = <&gmac0 miim
                      &gmac0 tx bus2
                      &gmac0 rx bus2
                      &gmac0 rgmii clk
                      &gmac0 rgmii bus
                      &eth0 pins
                      &gmac0_clkinout>;
        tx_delay = <0x3c>;
        rx delay = <0x2f>;
        phy-handle = <&rgmii phy0>;
        status = "okay";
};
&mdio0 {
        rgmii_phy0: phy@0 {
                compatible = "ethernet-phy-ieee802.3-c22";
                reg = <0x0>;
                clocks = <&cru CLK MAC0 OUT>;
        };
};
```

```
&gmac1 {
        phy-mode = "rgmii";
        clock in out = "input";
        snps,reset-gpio = <&gpio2 RK_PD1 GPIO_ACTIVE_LOW>;
        snps,reset-active-low;
        /* Reset time is 20ms, 100ms for rtl8211f */
        snps,reset-delays-us = <0 20000 100000>;
        assigned-clocks = <&cru SCLK_GMAC1_RX_TX>, <&cru SCLK_GMAC1>, <&cru
CLK_MAC1_OUT>;
       assigned-clock-parents = <&cru SCLK GMAC1 RGMII SPEED>, <&gmac1 clkin>;
        assigned-clock-rates = <0>, <125000000>, <25000000>;
        pinctrl-names = "default";
         pinctrl-0 = < &gmac1m0 miim
                      &gmac1m0 tx bus2
                      &gmac1m0 rx bus2
                      &gmac1m0 rgmii clk
                      &gmac1m0 rgmii bus
                      &eth1m0 pins
                      &gmac1m0_clkinout>;
        tx delay = <0x4f>;
        rx delay = <0x26>;
       phy-handle = <&rgmii_phy1>;
```

```
status = "okay";
};

&mdio0 {
          rgmii_phy1: phy@0 {
                compatible = "ethernet-phy-ieee802.3-c22";
                reg = <0x0>;
                clocks = <&cru CLK_MACO_OUT>;
                };
};
```

```
&gmac1 {
       phy-mode = "rgmii";
        clock in out = "input";
        snps,reset-gpio = <&gpio2 RK_PD1 GPIO_ACTIVE_LOW>;
        snps,reset-active-low;
        /* Reset time is 20ms, 100ms for rtl8211f */
        snps,reset-delays-us = <0 20000 100000>;
        assigned-clocks = <&cru SCLK_GMAC1_RX_TX>, <&cru SCLK_GMAC1>, <&cru
CLK_MAC1_OUT>;
       assigned-clock-parents = <&cru SCLK_GMAC1_RGMII_SPEED>, <&gmac1_clkin>;
        assigned-clock-rates = <0>, <125000000>, <25000000>;
        pinctrl-names = "default";
        pinctrl-0 = <&gmac1m1 miim</pre>
                     &gmac1m1_tx_bus2
                      &gmac1m1 rx bus2
                      &gmac1m1_rgmii_clk
                      &gmac1m1 rgmii bus
                      &eth1m1 pins
                      &gmac1m1_clkinout>;
        tx_delay = <0x4f>;
        rx delay = <0x26>;
        phy-handle = <&rgmii_phy1>;
        status = "okay";
};
&mdio1 {
        rgmii_phy1: phy@0 {
                compatible = "ethernet-phy-ieee802.3-c22";
                reg = <0x0>;
                clocks = <&cru CLK MAC1 OUT>;
        } ;
};
```

#### 3.9.5 RGMII Crystal 25M for PHY, PLL output 125M for TX CLK

• gmac0

```
&gmac0 {
        phy-mode = "rgmii";
        clock in out = "output";
        assigned-clocks = <&cru SCLK_GMACO_RX_TX>, <&cru SCLK_GMACO>;
        assigned-clock-parents = <&cru SCLK GMACO RGMII SPEED>;
        assigned-clock-rates = <0>, <125000000>;
        snps,reset-gpio = <&gpio2 RK PD3 GPIO ACTIVE LOW>;
        snps,reset-active-low;
        /* Reset time is 20ms, 100ms for rtl8211f */
        snps,reset-delays-us = <0 20000 100000>;
        pinctrl-names = "default";
        pinctrl-0 = <&gmac0 miim
                      &gmac0_tx_bus2
                      &gmac0_rx_bus2
                      &gmac0 rgmii clk
                      &gmac0 rgmii bus>;
        tx_delay = <0x3c>;
       rx_delay = <0x2f>;
       phy-handle = <&rgmii phy0>;
        status = "okay";
};
&mdio0 {
       rgmii_phy0: phy@0 {
               compatible = "ethernet-phy-ieee802.3-c22";
                reg = <0x0>;
        };
};
```

```
+ &gmaclm0_rgmii_bus>;

    tx_delay = <0x4f>;
    rx_delay = <0x26>;

    phy-handle = <&rgmii_phy1>;
    status = "okay";
};

&mdio1 {
        rgmii_phy1: phy@0 {
             compatible = "ethernet-phy-ieee802.3-c22";
             reg = <0x0>;
        };
};
```

```
&gmac1 {
        phy-mode = "rgmii";
        clock in out = "output";
        snps,reset-gpio = <&gpio2 RK_PD1 GPIO_ACTIVE_LOW>;
        snps,reset-active-low;
        /* Reset time is 20ms, 100ms for rt18211f */
        snps,reset-delays-us = <0 20000 100000>;
        assigned-clocks = <&cru SCLK_GMAC1_RX_TX>, <&cru SCLK_GMAC1>;
        assigned-clock-parents = <&cru SCLK GMAC1 RGMII SPEED>;
        assigned-clock-rates = <0>, <125000000>;
        pinctrl-names = "default";
        pinctrl-0 = <&gmac1m1 miim</pre>
                      &gmac1m1 tx bus2
                      &gmac1m1_rx_bus2
                      &gmac1m1_rgmii_clk
                      &gmac1m1 rgmii bus>;
        tx delay = <0x4f>;
        rx_delay = <0x26>;
       phy-handle = <&rgmii phy1>;
        status = "okay";
};
&mdio1 {
        rgmii_phy1: phy@0 {
                compatible = "ethernet-phy-ieee802.3-c22";
               reg = <0x0>;
        };
};
```

#### 3.9.6 RGMII Crystal 25M for PHY, RGMII CLK input 125M for TX CLK

• gmac0

```
&gmac0 {
       phy-mode = "rgmii";
        clock in out = "input";
        assigned-clocks = <&cru SCLK_GMACO_RX_TX>, <&cru SCLK_GMACO>;
        assigned-clock-parents = <&cru SCLK GMACO RGMII SPEED>, <&gmacO clkin>;
        assigned-clock-rates = <0>, <125000000>;
        snps,reset-gpio = <&gpio2 RK PD3 GPIO ACTIVE LOW>;
        snps,reset-active-low;
        /* Reset time is 20ms, 100ms for rtl8211f */
        snps,reset-delays-us = <0 20000 100000>;
        pinctrl-names = "default";
        pinctrl-0 = <&gmac0 miim
                      &gmac0 tx bus2
                     &gmac0_rx_bus2
                      &gmac0 rgmii clk
                      &gmac0 rgmii bus
                      &gmac0 clkinout>;
        tx_delay = <0x3c>;
       rx delay = <0x2f>;
       phy-handle = <&rgmii phy0>;
        status = "okay";
} ;
&mdio0 {
       rgmii_phy0: phy@0 {
               compatible = "ethernet-phy-ieee802.3-c22";
                reg = <0x0>;
        };
} ;
```

```
&gmac1 {
        phy-mode = "rgmii";
        clock_in_out = "input";
        snps,reset-gpio = <&gpio2 RK_PD1 GPIO_ACTIVE_LOW>;
        snps, reset-active-low;
        /* Reset time is 20ms, 100ms for rt18211f */
        snps,reset-delays-us = <0 20000 100000>;
        assigned-clocks = <&cru SCLK_GMAC1_RX_TX>, <&cru SCLK_GMAC1>;
         assigned-clock-parents = <&cru SCLK_GMAC1_RGMII_SPEED>, <&gmac1_clkin>;
         assigned-clock-rates = <0>, <125000000>;
         pinctrl-names = "default";
         pinctrl-0 = <&gmac1m1_miim</pre>
                      &gmac1m1_tx_bus2
                      &gmac1m1 rx bus2
                      &gmac1m1 rgmii clk
                      &gmac1m1 rgmii bus
                      &gmac1m1_clkinout>;
        tx_delay = <0x4f>;
        rx_delay = <0x26>;
        phy-handle = <&rgmii_phy1>;
        status = "okay";
};
&mdio1 {
        rgmii phy1: phy@0 {
                compatible = "ethernet-phy-ieee802.3-c22";
                reg = <0x0>;
        };
};
```

#### 3.9.7 **SGMII**

DTS 除了配置 gmac 和 mac phy 节点外,还需要配置 xpcs 和 combophy 节点。

combophy

其中属性 rockchip, sgmii-mac-sel 表示使用的是哪个 gmac:

```
&combphyl_usq {
+ rockchip,sgmii-mac-sel = <0>; /* Use gmac0 for sgmii */
    status = "okay";
};
```

• xpcs

```
&xpcs {
    status = "okay";
};
```

• gmac0

```
&gmac0 {
       phy-mode = "sgmii";
        rockchip,pipegrf = <&pipegrf>;
       rockchip,xpcs = <&xpcs>;
        snps,reset-gpio = <&gpio2 RK_PC2 GPIO_ACTIVE_LOW>;
        snps, reset-active-low;
        snps,reset-delays-us = <0 20000 100000>;
        assigned-clocks = <&cru SCLK_GMAC0_RX_TX>;
        assigned-clock-parents = <&gmac0_xpcsclk>;
        pinctrl-names = "default";
       pinctrl-0 = <&gmac0 miim>;
       power-domains = <&power RK3568_PD_PIPE>;
       phys = <&combphy1 usq PHY TYPE SGMII>;
       phy-handle = <&sgmii phy>;
       status = "okay";
};
&mdio0 {
        sgmii_phy: phy@1 {
                compatible = "ethernet-phy-ieee802.3-c22";
                reg = <0x1>;
        };
} ;
```

#### • gmac1

```
&gmac1 {
    phy-mode = "sgmii";
```

```
rockchip,pipegrf = <&pipegrf>;
        rockchip,xpcs = <&xpcs>;
        snps,reset-gpio = <&gpio2 RK PC2 GPIO ACTIVE LOW>;
        snps,reset-active-low;
        snps,reset-delays-us = <0 20000 100000>;
        assigned-clocks = <&cru SCLK_GMAC1_RX_TX>;
        assigned-clock-parents = <&gmac1_xpcsclk>;
       pinctrl-names = "default";
       pinctrl-0 = <&gmac1_miim>;
       power-domains = <&power RK3568_PD_PIPE>;
        phys = <&combphy1_usq PHY_TYPE_SGMII>;
       phy-handle = <&sgmii phy>;
        status = "okay";
};
&mdio1 {
        sgmii_phy: phy@1 {
                compatible = "ethernet-phy-ieee802.3-c22";
               reg = <0x1>;
       } ;
};
```

# **3.9.8 QSGMII**

同 SGMIII 类似,DTS 除了配置 gmac 和 mac phy 节点外,还需要配置 xpcs 和 combophy 节点。

combophy

```
&combphy2_psq {
    status = "okay";
};
```

• xpcs

```
&xpcs {
    status = "okay";
};
```

```
&gmac0 {
    phy-supply = <&pcie20_3v3>;
    phy-mode = "qsgmii";
    rockchip,xpcs = <&xpcs>;

    snps,reset-gpio = <&gpio2 RK_PC2 GPIO_ACTIVE_LOW>;
    snps,reset-active-low;
    snps,reset-delays-us = <0 20000 1000000>;

assigned-clocks = <&cru SCLK_GMACO_RX_TX>;
    assigned-clock-parents = <&gmac0_xpcsclk>;
```

```
pinctrl-names = "default";
   pinctrl-0 = <&gmac0_miim>;
   power-domains = <&power RK3568 PD PIPE>;
   phys = <&combphy2 psq PHY TYPE QSGMII>;
   phy-handle = <&qsgmii_phy0>;
   status = "okay";
};
&gmac1 {
   phy-supply = <&pcie20 3v3>;
   phy-mode = "qsgmii";
   assigned-clocks = <&cru SCLK_GMAC1_RX_TX>;
   assigned-clock-parents = <&gmac1 xpcsclk>;
   power-domains = <&power RK3568_PD_PIPE>;
   phy-handle = <&qsgmii_phy1>;
   status = "okay";
} ;
&mdio0 {
   qsgmii phy0: phy@0 {
       compatible = "ethernet-phy-id001c.c942", "ethernet-phy-ieee802.3-c22";
       reg = <0x0>;
   };
   qsgmii_phy1: phy@1 {
       compatible = "ethernet-phy-id001c.c942", "ethernet-phy-ieee802.3-c22";
       reg = <0x1>;
   } ;
   qsgmii phy2: phy@2 {
       compatible = "ethernet-phy-id001c.c942", "ethernet-phy-ieee802.3-c22";
       reg = <0x2>;
   qsgmii phy3: phy@3 {
       compatible = "ethernet-phy-id001c.c942", "ethernet-phy-ieee802.3-c22";
       reg = <0x3>;
   } ;
};
```

#### 3.10 RK3588

#### 3.10.1 RMII Clock Output

• gmac0

```
&gmac0 {
+          phy-mode = "rmii";
+          clock_in_out = "output";

snps,reset-gpio = <&gpio4 RK_PB3 GPIO_ACTIVE_LOW>;
snps,reset-active-low;
```

```
/* Reset time is 20ms, 100ms for rtl8211f */
       snps,reset-delays-us = <0 20000 100000>;
       pinctrl-names = "default";
        pinctrl-0 = <&gmac0_miim</pre>
                     &gmac0_tx_bus2
                     &gmac0 rx bus2
                     &gmac0_clkinout>;
       phy-handle = <&rmii_phy>;
       status = "okay";
};
&mdio0 {
       rmii_phy: phy@1 {
              compatible = "ethernet-phy-ieee802.3-c22";
               reg = <0x1>;
       };
};
```

• gmac1:

```
&gmac1 {
       phy-mode = "rmii";
       clock_in_out = "output";
       snps,reset-gpio = <&gpio3 RK_PB2 GPIO_ACTIVE_LOW>;
       snps,reset-active-low;
       /* Reset time is 20ms, 100ms for rtl8211f */
       snps,reset-delays-us = <0 20000 100000>;
      pinctrl-names = "default";
       pinctrl-0 = <&gmac1 miim</pre>
                     &gmac1 tx bus2
                     &gmac1_rx_bus2
                     &gmac1_clkinout>;
       phy-handle = <&rmii phy>;
       status = "okay";
};
&mdio1 {
       rmii phy: phy@1 {
              compatible = "ethernet-phy-ieee802.3-c22";
               reg = <0x1>;
      };
};
```

# 3.10.2 RMII Clock Input

• gmac0

```
&gmac0 {
+         phy-mode = "rmii";
+         clock_in_out = "input";
```

```
snps,reset-gpio = <&gpio4 RK_PB3 GPIO_ACTIVE_LOW>;
       snps, reset-active-low;
       /* Reset time is 20ms, 100ms for rtl8211f */
       snps,reset-delays-us = <0 20000 100000>;
       pinctrl-names = "default";
      pinctrl-0 = <&gmac0_miim</pre>
                    &gmac0 tx bus2
                     &gmac0 rx bus2
                     &gmac0 clkinout>;
       phy-handle = <&rmii_phy>;
       status = "okay";
} ;
&mdio0 {
       rmii_phy: phy@1 {
             compatible = "ethernet-phy-ieee802.3-c22";
              reg = <0x1>;
      };
};
```

#### • gmac1:

```
&gmac1 {
+ phy-mode = "rmii";
  clock_in_out = "input";
   snps,reset-gpio = <&gpio3 RK_PB2 GPIO_ACTIVE_LOW>;
   snps,reset-active-low;
   /* Reset time is 20ms, 100ms for rtl8211f */
    snps,reset-delays-us = <0 20000 100000>;
+ pinctrl-names = "default";
  pinctrl-0 = <&gmac1_miim</pre>
                &gmac1 tx bus2
                 &gmac1 rx bus2
+
                 &gmac1 clkinout>;
   phy-handle = <&rmii_phy>;
   status = "okay";
} ;
&mdio1 {
   rmii phy: phy@1 {
      compatible = "ethernet-phy-ieee802.3-c22";
       reg = <0x1>;
   };
};
```

# 3.10.3 RGMII PLL output 25M for PHY, PLL output 125M for TX\_CLK

• gmac0

```
&gmac0 {
   /* Use rgmii-rxid mode to disable rx delay inside Soc */
 phy-mode = "rgmii-rxid";
   clock_in_out = "output";
   snps,reset-gpio = <&gpio4 RK_PB3 GPIO_ACTIVE_LOW>;
   snps,reset-active-low;
    /* Reset time is 20ms, 100ms for rtl8211f */
   snps, reset-delays-us = <0 20000 100000>;
+ pinctrl-names = "default";
  pinctrl-0 = <&gmac0_miim</pre>
            &gmac0 tx bus2
            &gmac0 rx bus2
            &gmac0_rgmii_clk
            &gmac0_rgmii_bus
            &eth0_pins>;
   tx delay = <0x45>;
   /* rx_delay = <0x43>; */
   phy-handle = <&rgmii phy>;
   status = "okay";
};
&mdio0 {
   rgmii_phy: phy@1 {
       compatible = "ethernet-phy-ieee802.3-c22";
       reg = <0x1>;
       clocks = <&cru REFCLKO25M ETHO OUT>;
   };
} ;
```

```
tx_delay = <0x45>;
  /* rx_delay = <0x43>; */

phy-handle = <&rgmii_phy>;
  status = "okay";
};

&mdio1 {
    rgmii_phy: phy@1 {
        compatible = "ethernet-phy-ieee802.3-c22";
        reg = <0x1>;
        reg = <0x1>;
};

clocks = <&cru REFCLKO25M_ETHO_OUT>;
};
};
```

## 3.10.4 RGMII PLL output 25M for PHY, RGMII\_CLK input 125M for TX\_CLK

```
&gmac0 {
  /* Use rgmii-rxid mode to disable rx delay inside Soc */
+ phy-mode = "rgmii-rxid";
+ clock in out = "input";
   snps,reset-gpio = <&gpio4 RK_PB3 GPIO_ACTIVE_LOW>;
   snps,reset-active-low;
   /* Reset time is 20ms, 100ms for rtl8211f */
   snps,reset-delays-us = <0 20000 100000>;
+ pinctrl-names = "default";
+ pinctrl-0 = <&gmac0_miim</pre>
           &gmac0_tx_bus2
           &gmac0 rx bus2
           &gmac0 rgmii clk
+
           &gmac0_rgmii_bus
           &gmac0 clkinout
            &eth0_pins>;
   tx delay = <0x45>;
   /* rx delay = <0x43>; */
   phy-handle = <&rgmii_phy>;
   status = "okay";
};
&mdio0 {
   rgmii_phy: phy@1 {
      compatible = "ethernet-phy-ieee802.3-c22";
       reg = <0x1>;
      clocks = <&cru REFCLKO25M ETHO OUT>;
   };
};
```

```
&gmac1 {
   /* Use rgmii-rxid mode to disable rx delay inside Soc */
+ phy-mode = "rgmii-rxid";
+ clock in out = "input";
   snps,reset-gpio = <&gpio3 RK_PB2 GPIO_ACTIVE_LOW>;
   snps,reset-active-low;
   /* Reset time is 20ms, 100ms for rtl8211f */
   snps,reset-delays-us = <0 20000 100000>;
+ pinctrl-names = "default";
  pinctrl-0 = <&gmac1_miim</pre>
           &gmac1 tx bus2
           &gmac1 rx bus2
           &gmac1_rgmii_clk
           &gmac1_rgmii_bus
            &gmac1 clkinout
            &eth1 pins>;
  tx_delay = <0x45>;
   /* rx delay = <0x43>; */
   phy-handle = <&rgmii phy>;
   status = "okay";
} ;
&mdio1 {
   rgmii phy: phy@1 {
       compatible = "ethernet-phy-ieee802.3-c22";
       reg = <0x1>;
      clocks = <&cru REFCLKO25M ETHO OUT>;
   } ;
};
```

## 3.10.5 RGMII Crystal 25M for PHY, PLL output 125M for TX\_CLK

```
&gmac0 {
    /* Use rgmii-rxid mode to disable rx delay inside Soc */
+ phy-mode = "rgmii-rxid";
+ clock_in_out = "output";

snps,reset-gpio = <&gpio4 RK_PB3 GPIO_ACTIVE_LOW>;
snps,reset-active-low;
/* Reset time is 20ms, 100ms for rtl8211f */
snps,reset-delays-us = <0 20000 1000000>;

+ pinctrl-names = "default";
+ pinctrl-0 = <&gmac0_miim
+ &gmac0_tx_bus2
+ &gmac0_rx_bus2
+ &gmac0_rgmii_clk
+ &gmac0_rgmii_clk
+ &gmac0_rgmii_bus>;
```

```
tx_delay = <0x45>;
    /* rx_delay = <0x43>; */

phy-handle = <&rgmii_phy>;
    status = "okay";
};

&mdio0 {
        rgmii_phy0: phy@0 {
             compatible = "ethernet-phy-ieee802.3-c22";
             reg = <0x0>;
        };
};
```

#### • gmac1

```
&gmac1 {
   /* Use rgmii-rxid mode to disable rx delay inside Soc */
  phy-mode = "rgmii-rxid";
 clock_in_out = "output";
   snps,reset-gpio = <&gpio3 RK PB2 GPIO ACTIVE LOW>;
   snps,reset-active-low;
   /* Reset time is 20ms, 100ms for rtl8211f */
   snps,reset-delays-us = <0 20000 100000>;
  pinctrl-names = "default";
  pinctrl-0 = <&gmac0_miim</pre>
            &gmac1 tx bus2
            &gmac1_rx_bus2
            &gmac1 rgmii clk
            &gmac1_rgmii_bus>;
   tx delay = <0x45>;
   /* rx_delay = <0x43>; */
   phy-handle = <&rgmii_phy>;
   status = "okay";
};
&mdio1 {
       rgmii_phy1: phy@0 {
               compatible = "ethernet-phy-ieee802.3-c22";
               reg = <0x0>;
       };
};
```

## 3.10.6 RGMII Crystal 25M for PHY, RGMII CLK input 125M for TX CLK

```
&gmac0 {
    /* Use rgmii-rxid mode to disable rx delay inside Soc */
+ phy-mode = "rgmii-rxid";
+ clock_in_out = "input";
```

```
snps,reset-gpio = <&gpio4 RK_PB3 GPIO_ACTIVE_LOW>;
   snps, reset-active-low;
   /* Reset time is 20ms, 100ms for rt18211f */
   snps, reset-delays-us = <0 20000 100000>;
 pinctrl-names = "default";
   pinctrl-0 = <&gmac0_miim</pre>
           &gmac0_tx_bus2
            &gmac0 rx bus2
            &gmac0 rgmii clk
            &gmac0 rgmii bus
            &gmac0_clkinout>;
   tx delay = <0x45>;
   /* rx delay = <0x43>; */
   phy-handle = <&rgmii_phy>;
   status = "okay";
};
&mdio0 {
        rgmii_phy0: phy@0 {
               compatible = "ethernet-phy-ieee802.3-c22";
               reg = <0x0>;
        };
};
```

```
&gmac1 {
  /* Use rgmii-rxid mode to disable rx delay inside Soc */
+ phy-mode = "rgmii-rxid";
+ clock in out = "input";
   snps,reset-gpio = <&gpio3 RK_PB2 GPIO_ACTIVE_LOW>;
   snps,reset-active-low;
    /* Reset time is 20ms, 100ms for rt18211f */
   snps,reset-delays-us = <0 20000 100000>;
  pinctrl-names = "default";
 pinctrl-0 = <&gmac0 miim
            &gmac1 tx bus2
+
            &gmac1 rx bus2
            &gmac1_rgmii_clk
            &gmac1 rgmii bus
            &gmac1 clkinout>;
   tx delay = <0x45>;
   /* rx delay = <0x43>; */
   phy-handle = <&rgmii_phy>;
   status = "okay";
};
&mdio1 {
      rgmii_phy1: phy@0 {
```

```
compatible = "ethernet-phy-ieee802.3-c22";
reg = <0x0>;
};
};
```

# 3.11 RV1108

### 3.11.1 RMII Clock Input

```
+gmac_clkin: gmac_clkin {
     compatible = "fixed-clock";
       clock-output-names = "gmac clkin";
       clock-frequency = <50000000>;
       #clock-cells = <0>;
+};
&gmac {
      phy-mode = "rmii";
       clock_in_out = "input";
       assigned-clocks = <&cru SCLK_MAC>;
       assigned-clock-parents = <&gmac_clkin>;
       snps, reset-gpio = < & gpio 3 12 0>;
        snps,reset-active-low;
       snps,reset-delays-us = <0 20000 100000>;
       pinctrl-names = "default";
       pinctrl-0 = <&rmii pins>;
      status = "ok";
};
```

# 3.11.2 RMII Clock Output

## 3.12.1 RGMII PLL output 25M for PHY, PLL output 125M for TX CLK

• gmac m0

```
&gmac {
+ phy-mode = "rgmii";
+ clock_in_out = "output";
   snps,reset-gpio = <&gpio3 RK PA0 GPIO ACTIVE LOW>;
   snps,reset-active-low;
   /* Reset time is 20ms, 100ms for rtl8211f */
   snps,reset-delays-us = <0 20000 100000>;
+ assigned-clocks = <&cru CLK GMAC SRC>, <&cru CLK GMAC TX RX>, <&cru
CLK GMAC ETHERNET OUT>;
  assigned-clock-parents = <&cru CLK_GMAC_SRC_MO>, <&cru RGMII_MODE_CLK>;
  assigned-clock-rates = <125000000>, <0>, <25000000>;
+ pinctrl-names = "default";
  pinctrl-0 = <&rgmiim0_miim &rgmiim0_bus2 &rgmiim0_bus4 &clkm0_out_ethernet>;
   tx delay = <0x2a>;
   rx_delay = <0x1a>;
   phy-handle = <&phy>;
   status = "okay";
};
&mdio {
   phy: phy@0 {
       compatible = "ethernet-phy-ieee802.3-c22";
       reg = <0x0>;
       clocks = <&cru CLK_GMAC_ETHERNET_OUT>;
   } ;
};
```

```
+ pinctrl-names = "default";
+ pinctrl-0 = <&rgmiim1_miim &rgmiim1_bus2 &rgmiim1_bus4 &clkm1_out_ethernet>;

tx_delay = <0x2a>;
    rx_delay = <0x1a>;

phy-handle = <&phy>;
    status = "okay";
};

&mdio {
    phy: phy@0 {
        compatible = "ethernet-phy-ieee802.3-c22";
        reg = <0x0>;
+        clocks = <&cru CLK_GMAC_ETHERNET_OUT>;
    };
};
```

### 3.12.2 RGMII PLL output 25M for PHY, RGMII Clock input 125M for TX CLK

```
&gmac {
+ phy-mode = "rgmii";
+ clock in out = "input";
   snps,reset-gpio = <&gpio3 RK_PA0 GPIO_ACTIVE_LOW>;
   snps,reset-active-low;
   /* Reset time is 20ms, 100ms for rtl8211f */
   snps,reset-delays-us = <0 20000 100000>;
+ assigned-clocks = <&cru CLK_GMAC_SRC>, <&cru CLK_GMAC_TX_RX>, <&cru
CLK GMAC ETHERNET OUT>;
+ assigned-clock-parents = <&cru CLK GMAC SRC MO>, <&cru RGMII MODE CLK>;
  assigned-clock-rates = <125000000>, <0>, <25000000>;
+ pinctrl-names = "default";
+ pinctrl-0 = <&rgmiim0 miim &rgmiim0 bus2 &rgmiim0 bus4 &clkm0 out ethernet>;
   tx delay = <0x2a>;
   rx delay = <0x1a>;
   phy-handle = <&phy>;
   status = "okay";
};
&mdio {
  phy: phy@0 {
       compatible = "ethernet-phy-ieee802.3-c22";
       reg = <0x0>;
      clocks = <&cru CLK GMAC ETHERNET OUT>;
   } ;
};
```

```
&gmac {
+ phy-mode = "rgmii";
+ clock in out = "input";
   snps,reset-gpio = <&gpio3 RK_PA0 GPIO_ACTIVE_LOW>;
   snps,reset-active-low;
    /* Reset time is 20ms, 100ms for rtl8211f */
   snps,reset-delays-us = <0 20000 100000>;
+ assigned-clocks = <&cru CLK_GMAC_SRC>, <&cru CLK_GMAC_TX_RX>, <&cru
CLK GMAC ETHERNET OUT>;
  assigned-clock-parents = <&cru CLK GMAC SRC M1>, <&cru RGMII MODE CLK>;
+ assigned-clock-rates = <125000000>, <0>, <25000000>;
+ pinctrl-names = "default";
+ pinctrl-0 = <&rgmiim1_miim &rgmiim1_bus2 &rgmiim1_bus4 &clkm1_out_ethernet>;
   tx delay = <0x2a>;
   rx_delay = <0x1a>;
   phy-handle = <&phy>;
   status = "okay";
};
&mdio {
   phy: phy@0 {
       compatible = "ethernet-phy-ieee802.3-c22";
       reg = <0x0>;
       clocks = <&cru CLK_GMAC_ETHERNET_OUT>;
   } ;
};
```

#### 3.12.3 RGMII Crytal 25M for PHY, PLL output 125M for TX CLK

```
phy-handle = <&phy>;
    status = "okay";
};

&mdio {
    phy: phy@0 {
        compatible = "ethernet-phy-ieee802.3-c22";
        reg = <0x0>;
    };
};
```

#### • gmac m1

```
&gmac {
+ phy-mode = "rgmii";
+ clock in out = "output";
   snps,reset-gpio = <&gpio3 RK_PA0 GPIO_ACTIVE_LOW>;
   snps,reset-active-low;
   /* Reset time is 20ms, 100ms for rtl8211f */
   snps, reset-delays-us = <0 20000 100000>;
+ assigned-clocks = <&cru CLK_GMAC_SRC>, <&cru CLK_GMAC_TX_RX>;
+ assigned-clock-parents = <&cru CLK_GMAC_SRC_M1>, <&cru RGMII_MODE_CLK>;
  assigned-clock-rates = <125000000>, <0>;
+ pinctrl-names = "default";
+ pinctrl-0 = <&rgmiim1_miim &rgmiim1_bus2 &rgmiim1_bus4 &clkm1_out_ethernet>;
   tx delay = <0x2a>;
   rx delay = <0x1a>;
   phy-handle = <&phy>;
   status = "okay";
};
&mdio {
   phy: phy@0 {
       compatible = "ethernet-phy-ieee802.3-c22";
       reg = <0x0>;
   } ;
} ;
```

## 3.12.4 RGMII Crytal 25M for PHY, RGMII CLK input 125M for TX CLK

```
+ assigned-clocks = <&cru CLK_GMAC_RGMII_MO>, <&cru CLK_GMAC_SRC_MO>, <&cru
CLK GMAC SRC>, <&cru CLK GMAC TX RX>;
+ assigned-clock-parents = <&gmac clkin m0>, <&cru CLK GMAC RGMII M0>, <&cru
CLK GMAC SRC MO>, <&cru RGMII MODE CLK>;
+ pinctrl-names = "default";
+ pinctrl-0 = <&rgmiim0 miim &rgmiim0 bus2 &rgmiim0 bus4>;
   tx delay = <0x2a>;
   rx delay = <0x1a>;
   phy-handle = <&phy>;
   status = "okay";
};
&mdio {
   phy: phy@0 {
      compatible = "ethernet-phy-ieee802.3-c22";
       reg = <0x0>;
   };
} ;
```

```
&gmac {
+ phy-mode = "rgmii";
+ clock_in_out = "input";
   snps,reset-gpio = <&gpio3 RK_PA0 GPIO_ACTIVE_LOW>;
   snps,reset-active-low;
   /* Reset time is 20ms, 100ms for rtl8211f */
   snps,reset-delays-us = <0 20000 100000>;
+ assigned-clocks = <&cru CLK_GMAC_SRC>, <&cru CLK_GMAC_TX_RX>, <&cru
CLK_GMAC_ETHERNET_OUT>;
+ assigned-clock-parents = <&cru CLK GMAC SRC M1>, <&cru RGMII MODE CLK>;
   assigned-clock-rates = <125000000>, <0>, <25000000>;
+ pinctrl-names = "default";
+ pinctrl-0 = <&rgmiim1_miim &rgmiim1_bus2 &rgmiim1_bus4>;
   tx delay = <0x2a>;
   rx delay = <0x1a>;
   phy-handle = <&phy>;
   status = "okay";
};
&mdio {
   phy: phy@0 {
       compatible = "ethernet-phy-ieee802.3-c22";
       reg = <0x0>;
   };
};
```

### 3.12.5 RMII Clock Output

• gmac m0

```
&gmac {
+ phy-mode = "rmii";
+ clock_in_out = "output";
   snps,reset-gpio = <&gpio3 RK PC5 GPIO ACTIVE LOW>;
   snps, reset-active-low;
   snps, reset-delays-us = <0 50000 50000>;
+ assigned-clocks = <&cru CLK GMAC SRC M0>, <&cru CLK GMAC SRC>, <&cru
CLK GMAC TX RX>;
+ assigned-clock-rates = <0>, <50000000>;
+ assigned-clock-parents = <&cru CLK_GMAC_RGMII_M0>, <&cru CLK_GMAC_SRC_M0>,
<&cru RMII MODE CLK>;
+ pinctrl-names = "default";
+ pinctrl-0 = <&rmiim0_miim &rgmiim0_rxer &rmiim0_bus2 &rgmiim0_mclkinout>;
   phy-handle = <&phy>;
   status = "okay";
};
&mdio {
   phy: phy@0 {
      compatible = "ethernet-phy-ieee802.3-c22";
       reg = <0x0>;
   };
};
```

```
&gmac {
+ phy-mode = "rmii";
+ clock_in_out = "output";
   snps,reset-gpio = <&gpio3 RK PC5 GPIO ACTIVE LOW>;
   snps,reset-active-low;
   snps,reset-delays-us = <0 50000 50000>;
+ assigned-clocks = <&cru CLK GMAC SRC M1>, <&cru CLK GMAC SRC>, <&cru
CLK GMAC TX RX>;
  assigned-clock-rates = <0>, <50000000>;
+ assigned-clock-parents = <&cru CLK GMAC RGMII M1>, <&cru CLK GMAC SRC M1>,
<&cru RMII MODE CLK>;
+ pinctrl-names = "default";
  pinctrl-0 = <@rmiim1 miim @rgmiim1 rxer @rmiim10 bus2 @rgmiim1 mclkinout>;
   phy-handle = <&phy>;
   status = "okay";
};
&mdio {
```

```
phy: phy@0 {
    compatible = "ethernet-phy-ieee802.3-c22";
    reg = <0x0>;
};
```

# 3.12.6 RMII Clock Input

• gmac m0

```
+&gmac_clkin_m0 {
+ clock-frequency = <50000000>;
+};
&gmac {
+ phy-mode = "rmii";
+ clock in out = "input";
   snps,reset-gpio = <&gpio3 RK_PC5 GPIO_ACTIVE_LOW>;
   snps,reset-active-low;
   snps, reset-delays-us = <0 50000 50000>;
+ assigned-clocks = <&cru CLK GMAC RGMII M0>, <&cru CLK GMAC SRC M0>, <&cru
CLK GMAC SRC>, <&cru CLK GMAC TX RX>;
+ assigned-clock-rates = <0>, <0>, <50000000>;
+ assigned-clock-parents = <&gmac_clkin_m0>,<&cru CLK_GMAC_RGMII_M0>, <&cru
CLK_GMAC_SRC_M0>, <&cru RMII_MODE_CLK>;
+ pinctrl-names = "default";
+ pinctrl-0 = <&rmiim0_miim &rgmiim0_rxer &rmiim0_bus2</pre>
&rgmiim0_mclkinout_level0>;
   phy-handle = <&phy>;
   status = "okay";
} ;
&mdio {
  phy: phy@0 {
       compatible = "ethernet-phy-ieee802.3-c22";
       reg = <0x0>;
   };
} ;
```

```
+&gmac_clkin_m1 {
+    clock-frequency = <50000000>;
+};

&gmac {
+    phy-mode = "rmii";
+    clock_in_out = "input";

snps,reset-gpio = <&gpio3 RK_PC5 GPIO_ACTIVE_LOW>;
snps,reset-active-low;
```

```
snps,reset-delays-us = <0 50000 50000>;
+ assigned-clocks = <&cru CLK_GMAC_RGMII_M1>, <&cru CLK_GMAC_SRC_M1>, <&cru
CLK_GMAC_SRC>, <&cru CLK_GMAC_TX_RX>;
+ assigned-clock-rates = <0>, <0>, <50000000>;
+ assigned-clock-parents = <&gmac_clkin_m1>,<&cru CLK_GMAC_RGMII_M1>, <&cru
CLK_GMAC_SRC_M1>, <&cru RMII_MODE_CLK>;
+ pinctrl-names = "default";
+ pinctrl-0 = <&rmiim1_miim &rgmiim1_rxer &rmiim1_bus2</pre>
&rgmiim1 mclkinout level0>;
   phy-handle = <&phy>;
   status = "okay";
} ;
&mdio {
   phy: phy@0 {
      compatible = "ethernet-phy-ieee802.3-c22";
       reg = <0x0>;
   } ;
} ;
```